package cn.edu.tju.wallet.repository;

import cn.edu.tju.wallet.domain.OverdraftRule;
import cn.edu.tju.wallet.domain.OverdraftRule.RuleStatus;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Optional;

/**
 * 透支规则Repository接口
 */
@Repository
public interface OverdraftRuleRepository extends JpaRepository<OverdraftRule, Long> {

    /**
     * 查询所有激活的透支规则
     * @return 透支规则列表
     */
    List<OverdraftRule> findByStatus(RuleStatus status);

    /**
     * 根据VIP等级查询适用的透支规则（按VIP等级降序排列，取第一个）
     * @param vipLevel VIP等级
     * @return 透支规则
     */
    Optional<OverdraftRule> findFirstByStatusAndMinVipLevelLessThanEqualOrderByMinVipLevelDesc(
            RuleStatus status, Integer vipLevel);

    /**
     * 查询适用于指定VIP等级的所有规则
     * @param vipLevel VIP等级
     * @return 透支规则列表
     */
    List<OverdraftRule> findByStatusAndMinVipLevelLessThanEqualOrderByMinVipLevelDesc(
            RuleStatus status, Integer vipLevel);
}